home *** CD-ROM | disk | FTP | other *** search
/ AmigActive 10 / AACD 10.iso / AACD / Games / MAME / src / drivers / darkseal.c < prev    next >
C/C++ Source or Header  |  2000-04-08  |  20KB  |  573 lines

  1. /***************************************************************************
  2.  
  3.     Dark Seal (Rev 3)    (c) 1990 Data East Corporation (World version)
  4.     Dark Seal (Rev 1)    (c) 1990 Data East Corporation (World version)
  5.     Dark Seal            (c) 1990 Data East Corporation (Japanese version)
  6.     Gate Of Doom (Rev 4) (c) 1990 Data East Corporation (USA version)
  7.     Gate of Doom (Rev 1) (c) 1990 Data East Corporation (USA version)
  8.  
  9.     Emulation by Bryan McPhail, mish@tendril.co.uk
  10.  
  11. ***************************************************************************/
  12.  
  13. #include "driver.h"
  14. #include "vidhrdw/generic.h"
  15. #include "cpu/h6280/h6280.h"
  16.  
  17. int  darkseal_vh_start(void);
  18. void darkseal_vh_screenrefresh(struct osd_bitmap *bitmap,int full_refresh);
  19.  
  20. WRITE_HANDLER( darkseal_pf1_data_w );
  21. WRITE_HANDLER( darkseal_pf2_data_w );
  22. WRITE_HANDLER( darkseal_pf3_data_w );
  23. WRITE_HANDLER( darkseal_pf3b_data_w );
  24. WRITE_HANDLER( darkseal_control_0_w );
  25. WRITE_HANDLER( darkseal_control_1_w );
  26. WRITE_HANDLER( darkseal_palette_24bit_rg_w );
  27. WRITE_HANDLER( darkseal_palette_24bit_b_w );
  28. READ_HANDLER( darkseal_palette_24bit_rg_r );
  29. READ_HANDLER( darkseal_palette_24bit_b_r );
  30. extern unsigned char *darkseal_pf12_row, *darkseal_pf34_row;
  31. extern unsigned char *darkseal_pf1_data,*darkseal_pf2_data,*darkseal_pf3_data;
  32. static unsigned char *darkseal_ram;
  33.  
  34. /******************************************************************************/
  35.  
  36. static WRITE_HANDLER( darkseal_control_w )
  37. {
  38.     switch (offset) {
  39.     case 6: /* DMA flag */
  40.         buffer_spriteram_w(0,0);
  41.         return;
  42.     case 8: /* Sound CPU write */
  43.         soundlatch_w(0,data & 0xff);
  44.         cpu_cause_interrupt(1,H6280_INT_IRQ1);
  45.         return;
  46.       case 0xa: /* IRQ Ack (VBL) */
  47.         return;
  48.     }
  49. }
  50.  
  51. static READ_HANDLER( darkseal_control_r )
  52. {
  53.     switch (offset)
  54.     {
  55.         case 0: /* Dip Switches */
  56.             return (readinputport(3) + (readinputport(4) << 8));
  57.  
  58.         case 2: /* Player 1 & Player 2 joysticks & fire buttons */
  59.             return (readinputport(0) + (readinputport(1) << 8));
  60.  
  61.         case 4: /* Credits */
  62.             return readinputport(2);
  63.     }
  64.  
  65.     return 0xffff;
  66. }
  67.  
  68. /******************************************************************************/
  69.  
  70. static struct MemoryReadAddress darkseal_readmem[] =
  71. {
  72.     { 0x000000, 0x07ffff, MRA_ROM },
  73.     { 0x100000, 0x103fff, MRA_BANK1 },
  74.     { 0x120000, 0x1207ff, MRA_BANK2 },
  75.     { 0x140000, 0x140fff, darkseal_palette_24bit_rg_r },
  76.     { 0x141000, 0x141fff, darkseal_palette_24bit_b_r },
  77.     { 0x180000, 0x18000f, darkseal_control_r },
  78.     { 0x220000, 0x220fff, MRA_BANK3 },
  79.     { 0x222000, 0x222fff, MRA_BANK4 },
  80.     { -1 }  /* end of table */
  81. };
  82.  
  83. static struct MemoryWriteAddress darkseal_writemem[] =
  84. {
  85.     { 0x000000, 0x07ffff, MWA_ROM },
  86.     { 0x100000, 0x103fff, MWA_BANK1, &darkseal_ram },
  87.     { 0x120000, 0x1207ff, MWA_BANK2, &spriteram, &spriteram_size },
  88.     { 0x140000, 0x140fff, darkseal_palette_24bit_rg_w, &paletteram },
  89.     { 0x141000, 0x141fff, darkseal_palette_24bit_b_w, &paletteram_2 },
  90.     { 0x180000, 0x18000f, darkseal_control_w },
  91.      { 0x200000, 0x200fff, darkseal_pf3b_data_w }, /* 2nd half of pf3, only used on last level */
  92.     { 0x202000, 0x203fff, darkseal_pf3_data_w, &darkseal_pf3_data },
  93.     { 0x220000, 0x220fff, MWA_BANK3, &darkseal_pf12_row },
  94.     { 0x222000, 0x222fff, MWA_BANK4, &darkseal_pf34_row },
  95.     { 0x240000, 0x24000f, darkseal_control_0_w },
  96.     { 0x260000, 0x261fff, darkseal_pf2_data_w, &darkseal_pf2_data },
  97.     { 0x262000, 0x263fff, darkseal_pf1_data_w, &darkseal_pf1_data },
  98.     { 0x2a0000, 0x2a000f, darkseal_control_1_w },
  99.     { -1 }  /* end of table */
  100. };
  101.  
  102. /******************************************************************************/
  103.  
  104. static WRITE_HANDLER( YM2151_w )
  105. {
  106.     switch (offset) {
  107.     case 0:
  108.         YM2151_register_port_0_w(0,data);
  109.         break;
  110.     case 1:
  111.         YM2151_data_port_0_w(0,data);
  112.         break;
  113.     }
  114. }
  115.  
  116. static WRITE_HANDLER( YM2203_w )
  117. {
  118.     switch (offset) {
  119.     case 0:
  120.         YM2203_control_port_0_w(0,data);
  121.         break;
  122.     case 1:
  123.         YM2203_write_port_0_w(0,data);
  124.         break;
  125.     }
  126. }
  127.  
  128. static struct MemoryReadAddress sound_readmem[] =
  129. {
  130.     { 0x000000, 0x00ffff, MRA_ROM },
  131.     { 0x100000, 0x100001, YM2203_status_port_0_r },
  132.     { 0x110000, 0x110001, YM2151_status_port_0_r },
  133.     { 0x120000, 0x120001, OKIM6295_status_0_r },
  134.     { 0x130000, 0x130001, OKIM6295_status_1_r },
  135.     { 0x140000, 0x140001, soundlatch_r },
  136.     { 0x1f0000, 0x1f1fff, MRA_BANK8 },
  137.     { -1 }  /* end of table */
  138. };
  139.  
  140. static struct MemoryWriteAddress sound_writemem[] =
  141. {
  142.     { 0x000000, 0x00ffff, MWA_ROM },
  143.     { 0x100000, 0x100001, YM2203_w },
  144.     { 0x110000, 0x110001, YM2151_w },
  145.     { 0x120000, 0x120001, OKIM6295_data_0_w },
  146.     { 0x130000, 0x130001, OKIM6295_data_1_w },
  147.     { 0x1f0000, 0x1f1fff, MWA_BANK8 },
  148.     { 0x1fec00, 0x1fec01, H6280_timer_w },
  149.     { 0x1ff402, 0x1ff403, H6280_irq_status_w },
  150.     { -1 }  /* end of table */
  151. };
  152.  
  153. /******************************************************************************/
  154.  
  155. INPUT_PORTS_START( darkseal )
  156.     PORT_START    /* Player 1 controls */
  157.     PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_JOYSTICK_UP    | IPF_8WAY )
  158.     PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_JOYSTICK_DOWN  | IPF_8WAY )
  159.     PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_JOYSTICK_LEFT  | IPF_8WAY )
  160.     PORT_BIT( 0x08, IP_ACTIVE_LOW, IPT_JOYSTICK_RIGHT | IPF_8WAY )
  161.     PORT_BIT( 0x10, IP_ACTIVE_LOW, IPT_BUTTON1 )
  162.     PORT_BIT( 0x20, IP_ACTIVE_LOW, IPT_BUTTON2 )
  163.     PORT_BIT( 0x40, IP_ACTIVE_LOW, IPT_UNUSED )    /* button 3 - unused */
  164.     PORT_BIT( 0x80, IP_ACTIVE_LOW, IPT_START1 )
  165.  
  166.     PORT_START    /* Player 2 controls */
  167.     PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_JOYSTICK_UP    | IPF_8WAY | IPF_PLAYER2 )
  168.     PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_JOYSTICK_DOWN  | IPF_8WAY | IPF_PLAYER2 )
  169.     PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_JOYSTICK_LEFT  | IPF_8WAY | IPF_PLAYER2 )
  170.     PORT_BIT( 0x08, IP_ACTIVE_LOW, IPT_JOYSTICK_RIGHT | IPF_8WAY | IPF_PLAYER2 )
  171.     PORT_BIT( 0x10, IP_ACTIVE_LOW, IPT_BUTTON1 | IPF_PLAYER2 )
  172.     PORT_BIT( 0x20, IP_ACTIVE_LOW, IPT_BUTTON2 | IPF_PLAYER2 )
  173.     PORT_BIT( 0x40, IP_ACTIVE_LOW, IPT_UNUSED )    /* button 3 - unused */
  174.     PORT_BIT( 0x80, IP_ACTIVE_LOW, IPT_START2 )
  175.  
  176.     PORT_START    /* Credits */
  177.     PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_COIN1 )
  178.     PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_COIN2 )
  179.     PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_COIN3 )
  180.     PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_VBLANK )
  181.     PORT_BIT( 0x10, IP_ACTIVE_LOW, IPT_UNKNOWN )
  182.     PORT_BIT( 0x20, IP_ACTIVE_LOW, IPT_UNKNOWN )
  183.     PORT_BIT( 0x40, IP_ACTIVE_LOW, IPT_UNKNOWN )
  184.     PORT_BIT( 0x80, IP_ACTIVE_LOW, IPT_UNKNOWN )
  185.  
  186.     PORT_START    /* Dip switch bank 1 */
  187.     PORT_DIPNAME( 0x07, 0x07, DEF_STR( Coin_A ) )
  188.     PORT_DIPSETTING(    0x00, DEF_STR( 3C_1C ) )
  189.     PORT_DIPSETTING(    0x01, DEF_STR( 2C_1C ) )
  190.     PORT_DIPSETTING(    0x07, DEF_STR( 1C_1C ) )
  191.     PORT_DIPSETTING(    0x06, DEF_STR( 1C_2C ) )
  192.     PORT_DIPSETTING(    0x05, DEF_STR( 1C_3C ) )
  193.     PORT_DIPSETTING(    0x04, DEF_STR( 1C_4C ) )
  194.     PORT_DIPSETTING(    0x03, DEF_STR( 1C_5C ) )
  195.     PORT_DIPSETTING(    0x02, DEF_STR( 1C_6C ) )
  196.     PORT_DIPNAME( 0x38, 0x38, DEF_STR( Coin_B ) )
  197.     PORT_DIPSETTING(    0x00, DEF_STR( 3C_1C ) )
  198.     PORT_DIPSETTING(    0x08, DEF_STR( 2C_1C ) )
  199.     PORT_DIPSETTING(    0x38, DEF_STR( 1C_1C ) )
  200.     PORT_DIPSETTING(    0x30, DEF_STR( 1C_2C ) )
  201.     PORT_DIPSETTING(    0x28, DEF_STR( 1C_3C ) )
  202.     PORT_DIPSETTING(    0x20, DEF_STR( 1C_4C ) )
  203.     PORT_DIPSETTING(    0x18, DEF_STR( 1C_5C ) )
  204.     PORT_DIPSETTING(    0x10, DEF_STR( 1C_6C ) )
  205.     PORT_DIPNAME( 0x40, 0x40, DEF_STR( Flip_Screen ) )
  206.     PORT_DIPSETTING(    0x40, DEF_STR( Off ) )
  207.     PORT_DIPSETTING(    0x00, DEF_STR( On ) )
  208.     PORT_DIPNAME( 0x80, 0x80, DEF_STR( Unused ) )
  209.     PORT_DIPSETTING(    0x80, DEF_STR( Off ) )
  210.     PORT_DIPSETTING(    0x00, DEF_STR( On ) )
  211.  
  212.     PORT_START    /* Dip switch bank 2 */
  213.     PORT_DIPNAME( 0x03, 0x03, DEF_STR( Lives ) )
  214.     PORT_DIPSETTING(    0x00, "1" )
  215.     PORT_DIPSETTING(    0x01, "2" )
  216.     PORT_DIPSETTING(    0x03, "3" )
  217.     PORT_DIPSETTING(    0x02, "4" )
  218.     PORT_DIPNAME( 0x0c, 0x0c, DEF_STR( Difficulty ) )
  219.     PORT_DIPSETTING(    0x08, "Easy" )
  220.     PORT_DIPSETTING(    0x0c, "Normal" )
  221.     PORT_DIPSETTING(    0x04, "Hard" )
  222.     PORT_DIPSETTING(    0x00, "Hardest" )
  223.     PORT_DIPNAME( 0x30, 0x30, "Energy" )
  224.     PORT_DIPSETTING(    0x00, "2" )
  225.     PORT_DIPSETTING(    0x10, "2.5" )
  226.     PORT_DIPSETTING(    0x30, "3" )
  227.     PORT_DIPSETTING(    0x20, "4" )
  228.     PORT_DIPNAME( 0x40, 0x40, "Allow Continue" )
  229.     PORT_DIPSETTING(    0x00, DEF_STR( No ) )
  230.     PORT_DIPSETTING(    0x40, DEF_STR( Yes ) )
  231.     PORT_DIPNAME( 0x80, 0x00, DEF_STR( Demo_Sounds ) )
  232.     PORT_DIPSETTING(    0x80, DEF_STR( Off ) )
  233.     PORT_DIPSETTING(    0x00, DEF_STR( On ) )
  234. INPUT_PORTS_END
  235.  
  236. /******************************************************************************/
  237.  
  238. static struct GfxLayout charlayout =
  239. {
  240.     8,8,    /* 8*8 chars */
  241.     4096,
  242.     4,        /* 4 bits per pixel  */
  243.     { 0x00000*8, 0x10000*8, 0x8000*8, 0x18000*8 },
  244.     { 0, 1, 2, 3, 4, 5, 6, 7 },
  245.     { 0*8, 1*8, 2*8, 3*8, 4*8, 5*8, 6*8, 7*8 },
  246.     8*8    /* every char takes 8 consecutive bytes */
  247. };
  248.  
  249. static struct GfxLayout seallayout =
  250. {
  251.     16,16,
  252.     4096,
  253.     4,
  254.     { 8, 0,  0x40000*8+8, 0x40000*8,},
  255.     { 32*8+0, 32*8+1, 32*8+2, 32*8+3, 32*8+4, 32*8+5, 32*8+6, 32*8+7,
  256.         0, 1, 2, 3, 4, 5, 6, 7 },
  257.     { 0*16, 1*16, 2*16, 3*16, 4*16, 5*16, 6*16, 7*16,
  258.             8*16, 9*16, 10*16, 11*16, 12*16, 13*16, 14*16, 15*16 },
  259.     64*8
  260. };
  261.  
  262. static struct GfxLayout seallayout2 =
  263. {
  264.     16,16,
  265.     4096*2,
  266.     4,
  267.     { 8, 0, 0x80000*8+8, 0x80000*8 },
  268.     { 32*8+0, 32*8+1, 32*8+2, 32*8+3, 32*8+4, 32*8+5, 32*8+6, 32*8+7,
  269.         0, 1, 2, 3, 4, 5, 6, 7 },
  270.     { 0*16, 1*16, 2*16, 3*16, 4*16, 5*16, 6*16, 7*16,
  271.             8*16, 9*16, 10*16, 11*16, 12*16, 13*16, 14*16, 15*16 },
  272.     64*8
  273. };
  274.  
  275. static struct GfxDecodeInfo gfxdecodeinfo[] =
  276. {
  277.     { REGION_GFX1, 0, &charlayout,    0, 16 },    /* Characters 8x8 */
  278.     { REGION_GFX2, 0, &seallayout,  768, 16 },    /* Tiles 16x16 */
  279.     { REGION_GFX3, 0, &seallayout, 1024, 16 },    /* Tiles 16x16 */
  280.     { REGION_GFX4, 0, &seallayout2, 256, 32 },    /* Sprites 16x16 */
  281.     { -1 } /* end of array */
  282. };
  283.  
  284. /******************************************************************************/
  285.  
  286. static struct OKIM6295interface okim6295_interface =
  287. {
  288.     2,              /* 2 chips */
  289.     { 7757, 15514 },/* Frequency */
  290.     { REGION_SOUND1, REGION_SOUND2 },       /* memory regions */
  291.     { 50, 25 }        /* Note!  Keep chip 1 (voices) louder than chip 2 */
  292. };
  293.  
  294. static struct YM2203interface ym2203_interface =
  295. {
  296.     1,
  297.     32220000/8,    /* Accurate, audio section crystal is 32.220 MHz */
  298.     { YM2203_VOL(40,40) },
  299.     { 0 },
  300.     { 0 },
  301.     { 0 },
  302.     { 0 }
  303. };
  304.  
  305. static void sound_irq(int state)
  306. {
  307.     cpu_set_irq_line(1,1,state); /* IRQ 2 */
  308. }
  309.  
  310. static struct YM2151interface ym2151_interface =
  311. {
  312.     1,
  313.     32220000/9, /* Accurate, audio section crystal is 32.220 MHz */
  314.     { YM3012_VOL(45,MIXER_PAN_LEFT,45,MIXER_PAN_RIGHT) },
  315.     { sound_irq }
  316. };
  317.  
  318. static struct MachineDriver machine_driver_darkseal =
  319. {
  320.     /* basic machine hardware */
  321.     {
  322.          {
  323.             CPU_M68000, /* Custom chip 59 */
  324.             12000000,
  325.             darkseal_readmem,darkseal_writemem,0,0,
  326.             m68_level6_irq,1 /* VBL */
  327.         },
  328.         {
  329.             CPU_H6280 | CPU_AUDIO_CPU, /* Custom chip 45 */
  330.             32220000/8, /* Audio section crystal is 32.220 MHz */
  331.             sound_readmem,sound_writemem,0,0,
  332.             ignore_interrupt,0
  333.         }
  334.     },
  335.     58, 529, /* frames per second, vblank duration */
  336.     1,    /* 1 CPU slice per frame - interleaving is forced when a sound command is written */
  337.     0,
  338.  
  339.     /* video hardware */
  340.      32*8, 32*8, { 0*8, 32*8-1, 1*8, 31*8-1 },
  341.  
  342.     gfxdecodeinfo,
  343.     2048, 2048,
  344.     0,
  345.  
  346.     VIDEO_TYPE_RASTER | VIDEO_MODIFIES_PALETTE | VIDEO_UPDATE_BEFORE_VBLANK | VIDEO_BUFFERS_SPRITERAM,
  347.     0,
  348.     darkseal_vh_start,
  349.     0,
  350.     darkseal_vh_screenrefresh,
  351.  
  352.     /* sound hardware */
  353.     0,0,0,0,
  354.       {
  355.         {
  356.             SOUND_YM2203,
  357.             &ym2203_interface
  358.         },
  359.         {
  360.             SOUND_YM2151,
  361.             &ym2151_interface
  362.         },
  363.         {
  364.             SOUND_OKIM6295,
  365.             &okim6295_interface
  366.         }
  367.     }
  368. };
  369.  
  370. /******************************************************************************/
  371.  
  372. ROM_START( darkseal )
  373.     ROM_REGION( 0x80000, REGION_CPU1 ) /* 68000 code */
  374.     ROM_LOAD_EVEN( "ga04-3.rom",   0x00000, 0x20000, 0xbafad556 )
  375.     ROM_LOAD_ODD ( "ga01-3.rom",   0x00000, 0x20000, 0xf409050e )
  376.     ROM_LOAD_EVEN( "ga-00.rom",    0x40000, 0x20000, 0xfbf3ac63 )
  377.     ROM_LOAD_ODD ( "ga-05.rom",    0x40000, 0x20000, 0xd5e3ae3f )
  378.  
  379.     ROM_REGION( 0x10000, REGION_CPU2 )    /* Sound CPU */
  380.     ROM_LOAD( "fz-06.rom",    0x00000, 0x10000, 0xc4828a6d )
  381.  
  382.     ROM_REGION( 0x020000, REGION_GFX1 | REGIONFLAG_DISPOSE )
  383.     ROM_LOAD( "fz-02.rom",    0x000000, 0x10000, 0x3c9c3012 )    /* chars */
  384.     ROM_LOAD( "fz-03.rom",    0x010000, 0x10000, 0x264b90ed )
  385.  
  386.     ROM_REGION( 0x080000, REGION_GFX2 | REGIONFLAG_DISPOSE )
  387.     ROM_LOAD( "mac-03.rom",   0x000000, 0x80000, 0x9996f3dc ) /* tiles 1 */
  388.  
  389.     ROM_REGION( 0x080000, REGION_GFX3 | REGIONFLAG_DISPOSE )
  390.     ROM_LOAD( "mac-02.rom",   0x000000, 0x80000, 0x49504e89 ) /* tiles 2 */
  391.  
  392.     ROM_REGION( 0x100000, REGION_GFX4 | REGIONFLAG_DISPOSE )
  393.     ROM_LOAD( "mac-00.rom",   0x000000, 0x80000, 0x52acf1d6 ) /* sprites */
  394.     ROM_LOAD( "mac-01.rom",   0x080000, 0x80000, 0xb28f7584 )
  395.  
  396.     ROM_REGION( 0x20000, REGION_SOUND1 )    /* ADPCM samples */
  397.     ROM_LOAD( "fz-08.rom",    0x00000, 0x20000, 0xc9bf68e1 )
  398.  
  399.     ROM_REGION( 0x20000, REGION_SOUND2 )    /* ADPCM samples */
  400.     ROM_LOAD( "fz-07.rom",    0x00000, 0x20000, 0x588dd3cb )
  401. ROM_END
  402.  
  403. ROM_START( darksea1 )
  404.     ROM_REGION( 0x80000, REGION_CPU1 ) /* 68000 code */
  405.     ROM_LOAD_EVEN( "ga-04.rom",    0x00000, 0x20000, 0xa1a985a9 )
  406.     ROM_LOAD_ODD ( "ga-01.rom",    0x00000, 0x20000, 0x98bd2940 )
  407.     ROM_LOAD_EVEN( "ga-00.rom",    0x40000, 0x20000, 0xfbf3ac63 )
  408.     ROM_LOAD_ODD ( "ga-05.rom",    0x40000, 0x20000, 0xd5e3ae3f )
  409.  
  410.     ROM_REGION( 0x10000, REGION_CPU2 )    /* Sound CPU */
  411.     ROM_LOAD( "fz-06.rom",    0x00000, 0x10000, 0xc4828a6d )
  412.  
  413.     ROM_REGION( 0x020000, REGION_GFX1 | REGIONFLAG_DISPOSE )
  414.     ROM_LOAD( "fz-02.rom",    0x000000, 0x10000, 0x3c9c3012 )    /* chars */
  415.     ROM_LOAD( "fz-03.rom",    0x010000, 0x10000, 0x264b90ed )
  416.  
  417.     ROM_REGION( 0x080000, REGION_GFX2 | REGIONFLAG_DISPOSE )
  418.     ROM_LOAD( "mac-03.rom",   0x000000, 0x80000, 0x9996f3dc ) /* tiles 1 */
  419.  
  420.     ROM_REGION( 0x080000, REGION_GFX3 | REGIONFLAG_DISPOSE )
  421.     ROM_LOAD( "mac-02.rom",   0x000000, 0x80000, 0x49504e89 ) /* tiles 2 */
  422.  
  423.     ROM_REGION( 0x100000, REGION_GFX4 | REGIONFLAG_DISPOSE )
  424.     ROM_LOAD( "mac-00.rom",   0x000000, 0x80000, 0x52acf1d6 ) /* sprites */
  425.     ROM_LOAD( "mac-01.rom",   0x080000, 0x80000, 0xb28f7584 )
  426.  
  427.     ROM_REGION( 0x20000, REGION_SOUND1 )    /* ADPCM samples */
  428.     ROM_LOAD( "fz-08.rom",    0x00000, 0x20000, 0xc9bf68e1 )
  429.  
  430.     ROM_REGION( 0x20000, REGION_SOUND2 )    /* ADPCM samples */
  431.     ROM_LOAD( "fz-07.rom",    0x00000, 0x20000, 0x588dd3cb )
  432. ROM_END
  433.  
  434. ROM_START( darkseaj )
  435.     ROM_REGION( 0x80000, REGION_CPU1 ) /* 68000 code */
  436.     ROM_LOAD_EVEN( "fz-04.bin",    0x00000, 0x20000, 0x817faa2c )
  437.     ROM_LOAD_ODD ( "fz-01.bin",    0x00000, 0x20000, 0x373caeee )
  438.     ROM_LOAD_EVEN( "fz-00.bin",    0x40000, 0x20000, 0x1ab99aa7 )
  439.     ROM_LOAD_ODD ( "fz-05.bin",    0x40000, 0x20000, 0x3374ef8c )
  440.  
  441.     ROM_REGION( 0x10000, REGION_CPU2 )    /* Sound CPU */
  442.     ROM_LOAD( "fz-06.rom",    0x00000, 0x10000, 0xc4828a6d )
  443.  
  444.     ROM_REGION( 0x020000, REGION_GFX1 | REGIONFLAG_DISPOSE )
  445.     ROM_LOAD( "fz-02.rom",    0x000000, 0x10000, 0x3c9c3012 )    /* chars */
  446.     ROM_LOAD( "fz-03.rom",    0x010000, 0x10000, 0x264b90ed )
  447.  
  448.     ROM_REGION( 0x080000, REGION_GFX2 | REGIONFLAG_DISPOSE )
  449.     ROM_LOAD( "mac-03.rom",   0x000000, 0x80000, 0x9996f3dc ) /* tiles 1 */
  450.  
  451.     ROM_REGION( 0x080000, REGION_GFX3 | REGIONFLAG_DISPOSE )
  452.     ROM_LOAD( "mac-02.rom",   0x000000, 0x80000, 0x49504e89 ) /* tiles 2 */
  453.  
  454.     ROM_REGION( 0x100000, REGION_GFX4 | REGIONFLAG_DISPOSE )
  455.     ROM_LOAD( "mac-00.rom",   0x000000, 0x80000, 0x52acf1d6 ) /* sprites */
  456.     ROM_LOAD( "mac-01.rom",   0x080000, 0x80000, 0xb28f7584 )
  457.  
  458.     ROM_REGION( 0x20000, REGION_SOUND1 )    /* ADPCM samples */
  459.     ROM_LOAD( "fz-08.rom",    0x00000, 0x20000, 0xc9bf68e1 )
  460.  
  461.     ROM_REGION( 0x20000, REGION_SOUND2 )    /* ADPCM samples */
  462.     ROM_LOAD( "fz-07.rom",    0x00000, 0x20000, 0x588dd3cb )
  463. ROM_END
  464.  
  465. ROM_START( gatedoom )
  466.     ROM_REGION( 0x80000, REGION_CPU1 ) /* 68000 code */
  467.     ROM_LOAD_EVEN( "gb04-4",       0x00000, 0x20000, 0x8e3a0bfd )
  468.     ROM_LOAD_ODD ( "gb01-4",       0x00000, 0x20000, 0x8d0fd383 )
  469.     ROM_LOAD_EVEN( "ga-00.rom",    0x40000, 0x20000, 0xfbf3ac63 )
  470.     ROM_LOAD_ODD ( "ga-05.rom",    0x40000, 0x20000, 0xd5e3ae3f )
  471.  
  472.     ROM_REGION( 0x10000, REGION_CPU2 )    /* Sound CPU */
  473.     ROM_LOAD( "fz-06.rom",    0x00000, 0x10000, 0xc4828a6d )
  474.  
  475.     ROM_REGION( 0x020000, REGION_GFX1 | REGIONFLAG_DISPOSE )
  476.     ROM_LOAD( "fz-02.rom",    0x000000, 0x10000, 0x3c9c3012 )    /* chars */
  477.     ROM_LOAD( "fz-03.rom",    0x010000, 0x10000, 0x264b90ed )
  478.  
  479.     ROM_REGION( 0x080000, REGION_GFX2 | REGIONFLAG_DISPOSE )
  480.     ROM_LOAD( "mac-03.rom",   0x000000, 0x80000, 0x9996f3dc ) /* tiles 1 */
  481.  
  482.     ROM_REGION( 0x080000, REGION_GFX3 | REGIONFLAG_DISPOSE )
  483.     ROM_LOAD( "mac-02.rom",   0x000000, 0x80000, 0x49504e89 ) /* tiles 2 */
  484.  
  485.     ROM_REGION( 0x100000, REGION_GFX4 | REGIONFLAG_DISPOSE )
  486.     ROM_LOAD( "mac-00.rom",   0x000000, 0x80000, 0x52acf1d6 ) /* sprites */
  487.     ROM_LOAD( "mac-01.rom",   0x080000, 0x80000, 0xb28f7584 )
  488.  
  489.     ROM_REGION( 0x20000, REGION_SOUND1 )    /* ADPCM samples */
  490.     ROM_LOAD( "fz-08.rom",    0x00000, 0x20000, 0xc9bf68e1 )
  491.  
  492.     ROM_REGION( 0x20000, REGION_SOUND2 )    /* ADPCM samples */
  493.     ROM_LOAD( "fz-07.rom",    0x00000, 0x20000, 0x588dd3cb )
  494. ROM_END
  495.  
  496. ROM_START( gatedom1 )
  497.     ROM_REGION( 0x80000, REGION_CPU1 ) /* 68000 code */
  498.     ROM_LOAD_EVEN( "gb04.bin",     0x00000, 0x20000, 0x4c3bbd2b )
  499.     ROM_LOAD_ODD ( "gb01.bin",     0x00000, 0x20000, 0x59e367f4 )
  500.     ROM_LOAD_EVEN( "gb00.bin",     0x40000, 0x20000, 0xa88c16a1 )
  501.     ROM_LOAD_ODD ( "gb05.bin",     0x40000, 0x20000, 0x252d7e14 )
  502.  
  503.     ROM_REGION( 0x10000, REGION_CPU2 )    /* Sound CPU */
  504.     ROM_LOAD( "fz-06.rom",    0x00000, 0x10000, 0xc4828a6d )
  505.  
  506.     ROM_REGION( 0x020000, REGION_GFX1 | REGIONFLAG_DISPOSE )
  507.     ROM_LOAD( "fz-02.rom",    0x000000, 0x10000, 0x3c9c3012 )    /* chars */
  508.     ROM_LOAD( "fz-03.rom",    0x010000, 0x10000, 0x264b90ed )
  509.  
  510.       /* the following four have not been verified on a real Gate of Doom */
  511.     /* board - might be different from Dark Seal! */
  512.  
  513.     ROM_REGION( 0x080000, REGION_GFX2 | REGIONFLAG_DISPOSE )
  514.     ROM_LOAD( "mac-03.rom",   0x000000, 0x80000, 0x9996f3dc ) /* tiles 1 */
  515.  
  516.     ROM_REGION( 0x080000, REGION_GFX3 | REGIONFLAG_DISPOSE )
  517.     ROM_LOAD( "mac-02.rom",   0x000000, 0x80000, 0x49504e89 ) /* tiles 2 */
  518.  
  519.     ROM_REGION( 0x100000, REGION_GFX4 | REGIONFLAG_DISPOSE )
  520.     ROM_LOAD( "mac-00.rom",   0x000000, 0x80000, 0x52acf1d6 ) /* sprites */
  521.     ROM_LOAD( "mac-01.rom",   0x080000, 0x80000, 0xb28f7584 )
  522.  
  523.     ROM_REGION( 0x20000, REGION_SOUND1 )    /* ADPCM samples */
  524.     ROM_LOAD( "fz-08.rom",    0x00000, 0x20000, 0xc9bf68e1 )
  525.  
  526.     ROM_REGION( 0x20000, REGION_SOUND2 )    /* ADPCM samples */
  527.     ROM_LOAD( "fz-07.rom",    0x00000, 0x20000, 0x588dd3cb )
  528. ROM_END
  529.  
  530. /******************************************************************************/
  531.  
  532. static void darkseal_decrypt(void)
  533. {
  534.     unsigned char *RAM = memory_region(REGION_CPU1);
  535.     int i;
  536.  
  537.     for (i=0x00000; i<0x80000; i++)
  538.         RAM[i]=(RAM[i] & 0xbd) | ((RAM[i] & 0x02) << 5) | ((RAM[i] & 0x40) >> 5);
  539. }
  540.  
  541. static READ_HANDLER( darkseal_cycle_r )
  542. {
  543.     int b=READ_WORD(&darkseal_ram[0x6]);
  544.     int a=READ_WORD(&darkseal_ram[0x2e7e]);
  545.     int d=cpu_geticount();
  546.  
  547.     /* If possible skip this cpu segment - idle loop */
  548.     if (d>99 && d<0xf0000000) {
  549.         if (cpu_getpreviouspc()==0x160a && b==0xffff) {
  550.             cpu_spinuntil_int();
  551.             /* Update internal counter based on cycles left to run */
  552.             a=((a+d/54)-1)&0xffff; /* 54 cycles per loop increment */
  553.             WRITE_WORD(&darkseal_ram[0x2e7e],a);
  554.         }
  555.     }
  556.  
  557.     return b;
  558. }
  559.  
  560. static void init_darkseal(void)
  561. {
  562.     install_mem_read_handler(0, 0x100006, 0x100007, darkseal_cycle_r);
  563.     darkseal_decrypt();
  564. }
  565.  
  566. /******************************************************************************/
  567.  
  568. GAME( 1990, darkseal, 0,        darkseal, darkseal, darkseal, ROT0, "Data East Corporation", "Dark Seal (World revision 3)" )
  569. GAME( 1990, darksea1, darkseal, darkseal, darkseal, darkseal, ROT0, "Data East Corporation", "Dark Seal (World revision 1)" )
  570. GAME( 1990, darkseaj, darkseal, darkseal, darkseal, darkseal, ROT0, "Data East Corporation", "Dark Seal (Japan)" )
  571. GAME( 1990, gatedoom, darkseal, darkseal, darkseal, darkseal, ROT0, "Data East Corporation", "Gate of Doom (US revision 4)" )
  572. GAME( 1990, gatedom1, darkseal, darkseal, darkseal, darkseal, ROT0, "Data East Corporation", "Gate of Doom (US revision 1)" )
  573.